SMAIL

Section: Misc. Reference Manual Pages (X_MAN8_EXT_X)
Updated: 31 January 1988
Index Return to Main Contents
 

NAME

smail, sendmail, mailq, runq, rmail, rsmtp, smtpd, newaliases - mail delivery system  

SYNOPSIS

smail [ flags ] address...
X_SMAIL_NAME_X [ flags ] address ...
mailq
runq
rmail address ...
rsmtp
smtpd
newaliases  

DESCRIPTION

Smail is a program used for receiving and delivering mail. Its job is to take mail from sources on the local or on remote hosts and deliver to the appropriate destinations. This may be either on remote hosts or on the local machine. It is not intended to be a user interface for reading and submitting mail. See mailx(1) on System V, Mail(1) on BSD systems, or mail(1) on other systems for information on user interfaces.

Smail is invoked under a wide variety of names, which serve to isolate some of its major uses: receiving local mail, receiving remote mail, attempting delivery of undelivered mail and displaying information about undelivered mail.  

OPTIONS

All of these commands accept the same set of flags, differing mainly in their default mode of operation. Two exceptions are the rmail and rsmtp commands which support only a subset of the possible flags. These two commands are intended to be used from remote hosts through remote execution over UUCP (see uux(1)) and are thus limited in how much they can do.

The flags which are recognized by smail are:

-bc
Display the file COPYING, distributed with the source, which details your rights and restrictions for distributing this software.
-bd
Listen for connection requests on a socket bound in the internet domain. When a connection occurs, conduct an SMTP (Simple Mail Transfer Protocol) conversation with the peer process. Listening will only occur if BSD style internet networking functionality is available.
-bm
Deliver mail to the recipient addresses. This is the default mode of operation if invoked as sendmail, smail, rmail or send-mail.
-bp
List information about the messages currently in smail's input spool directories. This is the default mode of operation if invoked as mailq. With the -v or -d flag, a per-message transaction log is displayed for each message which shows what has happened to the message so far.
-bi
Initialize the aliases file, or a YP aliases file. The specific behavior of this command depends upon whether an aliases file is specified in the command with -oA file. If such an aliases file is specified, the file specifies input that will be used to build a DBM database with the same basename. The resulting DBM database is intended to be usable as a YP database. If smail was compiled with the sdbm package, distributed with smail, then the resulting database will not be usable by YP. The DBM database is rebuilt by calling mkdbm (see mkdbm(X_MAN8_EXT_X)) with the -y option.
If an aliases file was not specified with -oA, then the system default aliases file is rebuilt by calling the mkaliases program (see mkaliases(X_MAN8_EXT_X) for more information).
Both the mkdbm and mkaliases programs are executed from the directory indicated by the smail_util_dir attribute (by default X_UTIL_BIN_DIR_X).
-bP
Take the addresses given on the command line as config file variables (see smail(X_MAN5_EXT_X) for more information) and write the values for each variable on the standard output. References to variables, such as hostnames or uucp_name which may be computed at run time, will yield the values that smail would compute normally. For example, on my workstation, the command:

smail -bP hostnames max_message_size

produces the output:

futatsu.uts.amdahl.com:futatsu.amdahl.com 102400

With the -v or -d flag the variable names are displayed as well, so that the command:

smail -bP -v max_message_size

produces the output:

max_message_size=102400

In addition to other config file variables, the name primary_name will output the primary (or canonical) name for the local host which will be used by smail, and config_file will output the name of the primary configuration file. Also, the name help will produce a verbose listing of all variables associated with their type, one variable per line, and the name all will produce a verbose listing of all variables along with their values. It is equivalent to smail -bP -v followed by a list of the names of all configuration variables.

-bR
Enter the hostile mail domain of giant mail messages, and RFC standard scrolls. Attempt to make it down to protocol level 26 and back.
-bS
Read SMTP commands on standard input, but do not produce SMTP replies on standard output. All failures are reported by return mail, rather than through reply codes. This is suitable for setting up a batched form of SMTP between machines over a remote execution service like UUCP. This is the default mode of operation if invoked as rsmtp.
-bs
Read SMTP commands on standard input and produce SMTP replies on standard output. The currently implemented SMTP commands are HELO, MAIL FROM, RCPT TO, DATA, RSET, NOOP, VRFY, EXPN and QUIT. This is the default mode of operation if invoked as smtpd. For compatibility with some implementations of inetd(8N), if smtpd is started with no standard output, standard input will be dup(2)'d to standard output.
-bt
Enter address test mode. Read addresses on standard input and produce the parse results and host routing/resolving information on standard output. This is primarily useful for debugging smail or debugging new smail routers.
-bv
Verify a list of addresses by producing the list of addresses produced by aliasing and forwarding expansions and by host routing or resolving. Addresses which cannot be resolved are also displayed, along with the reasons why.
-C filename or -oC filename
Sets the pathname of the primary config file to use in reading global attribute values. If specified, then smail sets the effective uid and gid back to the real uid and gid, to avoid problems when installations allow smail to be set uid to the superuser. If the filename is - then no primary config file is read. This should only be used for debugging purposes.
-d[number] or -v[number]
turn on debugging. If a number is given, set the debugging level to that value, otherwise the debugging level is set to 1. No white space is allowed before the optional number. There is no differentiation between use of -d and -v.
-D file
Redirect debugging output to the indicated file. Normally, debugging output will disable background delivery because programs should not continue to write to standard error after the mail process exits. However, if a debug output file is specified, then background delivery can occur.
-em or -oem
Mail errors back to the sender (default).
-ee or -oee
These forms refer to a berkenet error processing style which is not supported. If used, errors will be mailed back to the sender.
-ep or -oep
Write errors to the standard error output.
-eq or -oeq
Do not send notification of errors to the sender. This only works for mail delivered locally. Errors encountered on remote hosts mail still result in returned mail. Supply a Precedence: junk header field to set this behavior on local and remote hosts.
-ew or -oew
Write errors to the sender's terminal using the write(1) command, if he is logged in. Otherwise, mail errors back to the sender. (This is currently not supported and is treated in the same manner as -oem)
-F fullname
Explicitly set the full name of the sender for incoming mail, used only if the operation mode is reception of a single mail message on standard input.
-f sender or -r sender
Explicitly set the sender address for incoming mail, used only if the operation mode is reception of a single mail message on standard input.
-h number
Sets the hopcount for a single message. If this is not specified, the hop count is computed from the number of Received: fields in the message header. The hopcount is used for a primitive form of infinite loop detection: a sufficiently large hop count will cause mail to be rejected.
-I or -oI
Use the hidden dot algorithm in reading the message. Lines with one or more dots at the beginning have the leading dot removed, while a line containing only a single dot ends the input message. This is always set for messages received using SMTP.
-i or -oi
Do not allow a single `.' to end an incoming message. Otherwise, a dot on a line by itself will end a message. This is the default if smail is invoked as rmail.
-m or -om
Allow retention of the sender as a recipient for alias and mailing list expansions that include the sender. If this is Not set, the sender will not receive a copy of the message only as a result of being in an alias or mailing list.
-N
Disable delivery of this message. All other processing is performed, and transports are expected to go through most of the steps involved in delivery. This is useful for debugging smail when you do not actually wish to have messages delivered.
-n
Do not perform alias processing. This only prevents expansion of entries in alias files. Mailing list files and forward files may still be expanded.
-odb
Deliver mail in background, if mail delivery is to be performed. Background delivery is not currently supported in the SMTP modes; foreground delivery is used instead.
-odf
Deliver mail in foreground, if mail delivery is to be performed.
-oD filename
Sets the pathname of the director file. This overrides the default name of the director file as well as any name set in a config file. If specified, then smail sets the effective uid and gid back to the real uid and gid, to avoid problems when installations allow smail to be set uid to the superuser. If the filename is - then no director file is read. This should only be used for debugging purposes.
-oE filename
Sets the pathname of the delivery retry control file. This overrides the default name of the retry file as well as any name set in a config file. If specified, then smail sets the effective uid and gid back to the real uid and gid, to avoid problems when installations allows smail to be set uid to the superuser (the normal case). If the filename is - then no retry file is read. This should only be used for debugging purposes.
-oL directory name
Sets the pathname of the smail library directory. This overrides the default value of smail_lib_dir compiled into the smail binary, as well as any name set in a config file. This string may be used to locate configuration files, such as the director, router and transport files, alias and path files, and mailing list directories.
-oQ filename
Sets the pathname of the hostname qualification file. This overrides the default name of the qualify file as well as any name set in a config file. If specified, then smail sets the effective uid and gid back to the real uid and gid, to avoid problems when installations allows smail to be set uid to the superuser (the normal case). If the filename is - then no qualify file is read. This should only be used for debugging purposes.
-oR filename
Sets the pathname of the router file. This overrides the default name of the router file as well as any name set in a config file. If specified, then smail sets the effective uid and gid back to the real uid and gid, to avoid problems when installations allows smail to be set uid to the superuser (the normal case). If the filename is - then no router file is read. This should only be used for debugging purposes.
-oT filename
Sets the pathname of the transport file. This overrides the default name of the transport file as well as any name set in a config file. If specified, then smail sets the effective uid and gid back to the real uid and gid, to avoid problems when installations allow smail to be set uid to the superuser. If the filename is - then no transport file is read. This should only be used for debugging purposes.
-Q or -odq
Spool incoming messages but do not actually perform delivery until a later queue. This mode of operation is somewhat more efficient in terms of CPU usage, though it does slow down the flow of mail.
-q[interval]
Cause smail to process its input spool directory. If an interval is given, smail will repeatedly check its input spool directory, sleeping for the given interval between checks. The interval is in seconds, though it can be defined as a sequence of numbers with suffixes of `s' for seconds, `m' for minutes, `h' for hours, `d' for days, `w' for weeks and `y' for years. For example, -q2h30m specifies an interval of two hours and 30 minutes. This flag is useful in conjunction with the -bd mode of operation and will cause the daemon process to wake up on these intervals and perform queue processing. Performing a single queue run is the default mode of operation if smail is invoked as runq.
-t
Extract addresses from the To:, Cc: and Bcc: fields of the message header. This is useful for user agents that do not wish to compute the recipient addresses themselves. In this mode, any addresses given on the command line are addresses that explicitly will NOT receive mail, even as a result of aliasing or forwarding expansions. This option is ignored unless smail is in the mode set by the -bm flag (which is the default mode).
-V or -bV
Print the smail version on the standard output.
-oU
Report memory usage when smail exits.
-oX mail-service
Set the TCP/IP service name or port number to be used for listening for SMTP requests. This can used in conjunction with the -bd mode to define alternate debugging versions of the smail SMTP listening daemon, which may be useful in testing a new installation.
-oMs sender_host
Specify the name of the system that send the mail message. This value can be included in expansion strings through the variable $sender_host.
-oMr sender_proto
Specify the protocol that was used by the sending host to deliver the mail message. This value can be included in expansion strings through the variable $sender_proto.
 

NORMAL USAGE

Under normal usage, one smail daemon exists which receives requests from remote hosts and processes the input spool directory at intervals. Such a daemon can be started from /etc/rc with a command such as

smail -bd -q1h

which will cause queue runs at one hour intervals.

New mail can be submitted from user agents by calling smail directly and passing a message on standard input. Mailers such as BSD Mail(1) and some System V mailx(1) programs submit mail by invoking smail with a command such as

smail -em -i recipient-address ...

Because smail also works correctly if invoked as sendmail it is common to install smail as /usr/lib/sendmail so that existing binaries on BSD systems, or other systems that current run sendmail, do not need to be modified to run smail instead.

Some user agents, such as GNU Emacs may wish to have smail decipher the recipient list from the header. These programs may invoke smail with a command such as

smail -em -t -i

To receive mail over UUCP, smail can be invoked directly from uuxqt as /bin/rmail. Alternately, /bin/rmail can be another program that invokes smail directly as

smail -em -i -fsender-address recipient address ...

It is common for the System V based /bin/rmail program to perform delivery by itself, resulting in mail bypassing smail altogether. Such systems should replace /bin/rmail with a copy of smail or modify /bin/rmail so that it executes a copy of smail with the arguments as given above.

NOTE:
In the future, a separate program may be distributed with smail to serve the function of rmail at a lower cost. This program will only write the input spool file, while allowing a smail daemon to process messages at a later time. This will save the cost of a complete exec(2) of smail for each incoming message.

An alternative method of receiving mail over UUCP is through the rsmtp command, which receives batched SMTP requests. This can be used between two sites running smail to gain many of the benefits of the SMTP protocol, such as the ability to use recipient addresses which UUX cannot correctly pass to a remote rmail program. For example, addresses containing quotes or spaces cannot be expected to pass correctly over an uux/rmail link. However a uux/rsmtp link can handle such cases.  

SENDMAIL COMPATIBILITY

Smail was designed to be a plug-in replacement for the BSD sendmail program, in that external programs can call smail in the same manner that they previously called sendmail and expect similar results. However, smail is completely different internally and has entirely different configuration files. As a result, the -o option to smail only sets a few configuration parameters which were felt to be commonly used by other programs. Also, for convenience, some new (upper case only) parameters are defined only in smail. Attempts to set other options using this flag are ignored. See the OPTIONS section for the complete list of supported -o options.

Because smail can be called in a manner very similar to sendmail it is common to install smail as /usr/lib/sendmail so that no other program need be modified to use the new mailer. Thus, once properly configured, smail can be installed into a current sendmail-based environment, including an environment without access to source, with minimal effort.  

SMAIL UNDER SYSTEM V

The easiest way to install smail on a System V host is to install it as /bin/rmail. An alternative is cause mailx(1) to call /usr/lib/sendmail by changine the mailx(1) configuration file /usr/lib/mailx/mailx.rc to include a line such as:

sendmail=/usr/lib/sendmail

System V's mail(1) command attempts to perform delivery by itself. Use of mail(1) to send mail should thus be discouraged unless mail(1) is modified to call smail to perform delivery.  

FILES

For many sites, the compiled in configuration of smail is sufficient and thus no configuration files are needed. The following files and directories are from the default smail configuration:

X_LIB_DIR_X/config
Optional general smail configuration. This file can override compiled-in configuration.
X_LIB_DIR_X/qualify
Optional hostname qualification configuration file.
X_LIB_DIR_X/directors
Optional configuration for smail directors, i.e., configured methods for resolving local addresses. This file replaces the compiled-in director configuration.
X_LIB_DIR_X/routers
Optional configuration for smail routers, i.e., configured methods for resolving or routing to remote hosts. This file replaces the compiled-in router configuration.
X_LIB_DIR_X/transports
Optional configuration for smail transports; i.e., configured methods of mail delivery. This file replaces the compiled-in transport configuration.
X_LIB_DIR_X/retry
Optional delivery retry configuration file; i.e., minimum time between retries, and maximum time to retry before giving up.

The following files are commonly used to locally redirect mail and to give paths to remote sites.

X_LIB_DIR_X/aliases
A file of aliases for local addresses.
X_LIB_DIR_X/paths
A file of paths to remote hosts.
X_LIB_DIR_X/lists
A directory of mailing list files.
X_MAILBOX_DIR_X
The directory for user mailbox files.
~/.forward
Lists of forwarding addresses for local users.

The smail mailer typically uses the following directories for working storage, and to hold incoming mail messages.

X_MAIN_SPOOL_DIR_X
The top of the spool directory hierarchy.
X_MAIN_SPOOL_DIR_X/input
Smail's spool directory for incoming messages.
X_MAIN_SPOOL_DIR_X/error
A directory for messages which failed for some reason that the site administrator should investigate.
X_MAIN_SPOOL_DIR_X/msglog
A directory of transaction logs for individual messages.
X_MAIN_SPOOL_DIR_X/lock
A directory used in smail input spool files.

The following files log the activity of the smail mailer. The system administrator should check and truncate these files from time.

X_LOGFILE_X
A log of smail transactions.
X_PANICLOG_X
A log of configuration or system errors encountered by smail.
 

DIAGNOSTICS

Exits with 0 if no errors, non-0 otherwise. See /usr/include/sysexits.h or src/exitcodes.h in the smail source for the list of possible exit codes.

If the -bd option was used, then bind() failed: Address already in use implies that another process is already listening on the SMTP socket.  

SEE ALSO

binmail(1), mailx(1) under System V, Mail(1) under BSD, pathto(X_MAN1_EXT_X), smail(X_MAN5_EXT_X), Smail Administration and Installation Guide, Smail Design Document, DARPA Internet Requests for Comments, RFC821, RFC822 and RFC976.  

BUGS

Many mail bugs are not smail bugs. Smail can't help it if remote sites trash your mail messages.

If you find any bugs, please mail a description to the address smail-bugs@veritas.com, along with any code fixes that you may have.

Setting the input spool directory processing interval to a period of more than 2147483647 seconds is silly and will result in an incorrectly calculated processing interval.

Route-addrs on protocol level 1 are too strong.  

COPYRIGHT

Copyright(C)1987, 1988 Ronald S. Karr and Landon Curt Noll
Copyright(C)1992 Ronald S. Karr
See a file COPYING, distributed with the source code, or type smail -bc for distribution rights and restrictions associated with this software.


 

Index

NAME
SYNOPSIS
DESCRIPTION
OPTIONS
NORMAL USAGE
SENDMAIL COMPATIBILITY
SMAIL UNDER SYSTEM V
FILES
DIAGNOSTICS
SEE ALSO
BUGS
COPYRIGHT

This document was created by man2html, using the manual pages.
Time: 06:53:21 GMT, May 19, 2025